package com.itheima.dao;

import com.itheima.pojo.Role;
import org.apache.ibatis.annotations.Param;

import java.util.List;
import java.util.Map;
import java.util.Set;

public interface RoleDao {
    // 新增角色
    void add(Role role);

    // 根据用户id 查询所有的角色
    Set<Role> findByUserId(Integer userId);

    // 根据条件查询
    List<Role> findByCondition(String queryString);

    // 根据id查询角色
    Role findByRoleId(Integer id);

    // 根据角色id查询对应的权限
    List<Integer> findPermissionIdsByRoleId(Integer id);

    // 删除与权限的中间表关系
    void deleteAssociation(Integer roleId);

    // 添加角色与权限关系
    void setPermissionAndRole(Map map);

    // 删除角色
    void delete(Integer id);
    //根据角色ID查询当前角色包含的菜单ID
    List<Integer> findMenuIdsByRoleId(Integer id);
    //删除外键关系
    void deleteRole_MenuNull(Integer roleId);
     //添加菜单
    void addRole_Menu(@Param("roleId") Integer roleId,@Param("integer") Integer integer);
    //根据id查询父id
    Integer findParentIdByMenuId(Integer integer);
}
